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(57) A method, apparatus and computer program 
for controlling data migration in an information process- 
ing system which includes a central processing unit 
(CPU), a new storage system connected to the CPU 
and an old storage system connected to the new stor- 
age system. In the information processing system data 
migration is conducted to transfer data from the old stor- 
age system to the new storage system. The invention 
operates by permitting access by the CPU to the stor- 
age systems during data migration. When an access by 
the CPU is generated the invention determines whether 
the access is to a region where data migration has been 
completed or to a region where data migration has not 
been completed. If the access is to a region where data 
migration has been completed, then processing of the 
access is handled by the new storage system. If the 
access is to a region where data migration has not been 
completed, then processing of the access is handled by 
the old storage system causing data related to the 
access to be transferred from the old storage system to 
the new storage system. The speed of data migration 
can be adjusted based upon the utilization of the 
resources of the information processing system and 
information of the priority of access to the new storage 
system by the CPU. 
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Description 

BACKGROUND OF THE INVENTION 

The present invention relates to the process of data 
migration between storage systems. More particularly, 
the present invention relates to a method, apparatus 
and computer program for use in a system that performs 
data migration between storage systems for causing the 
system to accept access to the storage systems even 
though data migration between the storage systems 
has not been completed 

Hereinafter the term "old" when used with other 
terms, for example, "old volume" indicates the 
resources of the system where the data originates dur- 
ing data migration. Further, hereinafter the term "new" 
when used with other terms, for example, "new volume" 
indicates the resources of the system where the data is 
destined during data migration. Data migration is the 
transferring of data from the old volume to the new vol- 
ume. A volume is a storage system implemented by 
disk, memory circuits or the like. 

During the process of data migration between the 
old volume and the new volume, where the CPU of the 
overall system reads data from the old volume and 
writes the data to the new volume, access by the CPU 
to volumes in response to a reguest generated by the 
execution of a job of a customer is prevented. Accesses 
to the volumes can sometimes be stopped for long time 
during data migration. Thus, the effectiveness of the 
overall system is reduced. 

To address this disadvantage. IBM corporation 
developed a method of data migration which permits 
access from the CPU (disclosed by IBM 3990 model 6 
Enhancements) using an extended remote copy func- 
tion (hereafter XRC) or a peer to peer remote copy func- 
tion (hereafter PPRC). This disadvantage was also 
addressed by EMC Corporation which developed a 
method of data migration that permits access from the 
CPU in Symmetrix Data Migration Service (SDMS) as 
described in the SYMMETRIX ICDA Family PRODUCT 
ANNOUNCEMENT SUMMARY, Noverrfcer 6th, 1995. 

The system with XRC is provided with a function of 
storing data, to be written to the old volume (disk sub- 
system), from the CPU into a disk controller in the old 
disk subsystem. The disk controller then stores the data 
into the old disk subsystem. In order to accomplish data 
migration the CPU has the function of reading the 
stored data from the old disk subsystem via the disk 
controller. Thereafter, the CPU writes the data to the 
new disk subsystem thereby completing data migration. 

After data migration has been completed, a request 
for access to the old disk subsystem generated by exe- 
cution of a customer job is prevented, until the path to 
the old disk subsystem is switched to that of the new 
disk subsystem. Access is then permitted to the new 
disk subsystem. 

The above-described system with XRC requires 



that the function of the XRC be provided in the old disk 
subsystem and the CPU. Intervention of the CPU is not 
required to perform the access. However, as with gen- 
eral data migration, the new setting for the new disk 

5 subsystem is required for the CPU. 

In the system with PPRC, the old disk subsystem 
and the new disk subsystem are connected to each 
other to permit communication between them. By writ- 
ing data to be written by the CPU to the new disk sub- 

w system through the connection, data migration during 
access from the CPU is enabled. As with the XRC, 
access generated by execution of the job of a customer 
after the completion of data migration is prevented until 
the path to the disk subsystems has been switched. In 

is the system with PPRC. intervention of the CPU to per- 
form the access, as with the system with the XRC, is not 
required. However, the old and the new disk subsys- 
tems must be provided with the function of the PPRC. 
In the system with SDMS in order to conduct data 

20 migration, first the access from the CPU to the old disk 
subsystem is stopped. Then the connection of the 
access path from the CPU to the old cfisk subsystem is 
changed to the connection of the access path from the 
CPU to the new disk subsystem through a new access 

25 path between the old disk subsystem and the new disk 
subsystem. By reading data from the old disk subsys- 
tem and writing it to the new disk subsystem through the 
new access path, data migration is started. After the 
start of data migration, the access from the CPU is 

30 restarted. If the access from the CPU is to a region 
where data migration has been completed, the new disk 
subsystem processes the data directly. If the access 
from the CPU is to a region where data migration has 
not been completed, after the data of the relevant tracks 

35 in the old disk subsystem is read and written into the 
new disk subsystem, the new disk subsystem proc- 
esses the data with normal processing. Thus, access 
from the CPU during data migration is enabled. 

The important feature of the function of the SDMS 

40 is that the old disk subsystem is not required to have the 
function of data migration. The priority of the order of 
volumes that are to be transferred faster can be defined 
at the start of data migration. However, after completion 
of data migration dual operation of the new disk subsys- 

45 tern and an alternate disk subsystem can not be con- 
ducted unless repeated data migration processes are 
performed using a Symmetrix Remote Data Facility. 

SUMMARY OF THE INVENTION 

50 

An object of the present invention is to provide a 
method, apparatus and computer program that allows 
for the safe writing of data by the CPU to the old and 
new volumes during data migration. 
55 Another object of the present invention is to provide 
a method, apparatus and computer program for per- 
forming a data migration process while enabling dual 
operation of old and new volumes immediately after 
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completion of data migration and enabling relatively 
immediate switching of the new volume to the old vol- 
ume when the new volume fafled during data migration. 

Yet another object of the present invention is to pro- 
vide a method, apparatus and computer program hav- s 
ing a function of automatically adjusting data migration 
speed during data migration depending on the state of 
the load to the new volume so as to give priority to 
accesses to the new volume by the CPU. 

Still yet another object of the present invention is to 10 
provide a method, apparatus and computer program for 
performing data migration in a manner that improves the 
performance of data migration and access to the vol- 
umes by the CPU. 

The present invention provides a method, appara- 75 
tus and computer program for performing data migration 
in a general purpose computer system. The general 
purpose computer (information processing) system 
includes a central processing unit (CPU), a new disk 
controller (CU), a new disk volume (VOL), an old CU 20 
and an old VOL The new CU and new VOL are the des- 
tination of data migration and the old CU and the old 
VOL are the origin of data migration. The new CU is pro- 
vided with a data migration control part that controls 
data migration of data between the old and new VOLs 25 
and a cache that stores data for later storage to the new 
VOL A CU and a VOL can be implemented by a disk 
subsystem or a server. 

The present invention provides a plurality of con- 
nections between the above-described elements. Par- 30 
ticularty, the present invention provides a connection 
between the CPU and the new CU and a connection 
between the new CU and the old CU. There are also 
connections between the new CU and the new VOL and 
between the old CU and the old VOL 35 

The connections between the CPU and the new CU 
and between the new CU and the old CU are configured 
to permit data migration from the old VOL to the new 
VOL When data migration is started, access by the 
CPU to the old and new VOLs is tenporarily stopped. 40 
After start of data migration, access from the CPU is 
permitted. 

In the present invention, upon issue of an access by 
the CPU the data migration control part in the new CU 
judges if the access is to a region where data migration as 
has been completed or to a region where data migration 
has not been completed. When the access by the CPU 
is to a region where data migration has been conpleted, 
the data exists in the new CU and the new CU responds 
to the access. When the access by the CPU is to a so 
region where data migration has not been conpleted, 
the data does not exist in the new CU. Thus, the data 
migration control part responds to the access by 
accessing the old CU through the connection between 
the old CU and the new CU to retrieve the data to the 55 
cache 18 in the new CU. After the CPU operates on the 
data, the data is then written to both the new CU and the 
okJCU. 



As per the above, in the present invention when the 
CPU accesses a region where data migration has not 
been completed, data from tracks read from the old vol- 
ume are stored to the new volume and the data once 
operated on is stored to both the old volume and the 
new volume. Further, when the data is to be written to 
the new volume, the data is also written to the old vol- 
ume. Thus, the new and the old volumes contain the 
same data at the regions where data migration has 
been completed. Therefore, immediate switching to 
dual operation after the completion of data migration is 
enabled. Also switching to the old volume is possible 
when a failure occurs in the new volume during data 
migration since the most recent update of data is 
reflected in the old volume The above-descrbed writing 
by the CPU to the new and old VOLs can be safely con- 
ducted during data migration. 

By reflecting data of tracks read from the old disk 
subsystem during access by the CPU to a region where 
data migration has not been completed to the new vol- 
ume, the data migration process can skip the tracks. 
Skipping tracks in the which data migration is not neces- 
sary improves the efficiency of the data migration proc- 
ess. Further, by leaving data of a track on the cache of 
the new CU allows for repeated access to the data by 
the CPU. Allowing for such repeated access to data in 
the cache improves the efficiency of access by the CPU 
during data migration. 

The present invention adjusts data migration speed 
based on various information of the system that have 
been acquired and analyzed. Such information includes 
information of the utilization of the cache in the new CU, 
information of the utilization of the connection between 
the new CU and the old CU, information of the utilization 
of the old VOL and information of the utilization of data 
migration speed at the current speed. The present 
invention provides a function where the data migration 
speed can be adjusted in a manner to give priority to 
axess of the old VOL by the CPU. 

BRIEF DESCRIPTION OF THE DRAWINGS 

The present invention will be more apparent from 
the following detailed description, when taken in con- 
junction with the accompanying drawings, in which: 

Fig. 1 illustrates the configuration of the presented 
invention for performing data migration in a general 
purpose computer system; 
Fig. 2 is a flowchart of the operations of data migra- 
tion performed by the data migration control part of 
the present invention; 

Fig. 3 is a flowchart of the operations performed by 
the present invention when access by the CPU 
occurs during data migration; and 
Fig. 4 is a flowchart of the operations performed by 
the present invention on the migrating side to adjust 
automatically data migration speed during data 
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migration. 

DESCRIPTION OF THE PREFERRED EMBODIMENT 

Figs. 1 -4 will be used to explain the features of the 
present invention for performing data migration in a gen- 
eral purpose computer system. 

Fig. 1 illustrates the configuration of the present 
invention for performing data migration in a general pur- 
pose computer (information processing) system that is 
the preferred embodiment of the present invention. The 
information processing system of the preferred embodi- 
ment of the present invention includes CPU 10 that is 
the central processing unit, a new disk controller unit 
(hereafter new CU) 1 1 and a new disk volume (hereafter 
new VOL) 12 that are the destination of data migration, 
and an old CU 13 and old VOL 14 that are the origin of 
data migration. The new CU 11 is provided with a data 
migration control part 17 that controls data migration of 
the data and a cache 18 that stores data. Here the new 
disk subsystem includes the new CU 11 and the new 
VOL 12, and the old disk subsystem includes the old CU 
13 and the old VOL 14. In the present invention a CU 
and its VOL can be implemented by a server. 

In the configuration connections are provided for 
performing the data migration process of the preferred 
embodiment of the present invention. The connections 
include a connection 15 between the CPU 10 and the 
new CU 1 1 , and a connection 16 between the new CU 
11 and the old CU 13. There is also a connection 
between the new CU 1 1 and the new VOL 12 and a con- 
nection between the old CU 13 and the old VOL 14. 

A flowchart of the operation of the preferred embod- 
iment of the present invention is explained below. The 
connections 15 and 16 are configured to permit data 
migration from the old VOL 1 4 to the new VOL 12. When 
data migration has been started, access by the CPU 10 
to the old and new VOLs 14 and 12 is temporarily 
stopped. Data migration from the old VOL 14 of the old 
CU 13 to the new VOL 12 of the new CU 11 is repre- 
sented by the dashed-fine arrow A. After the start of 
data migration, access from the CPU 10 is restarted. 
Therefore, accesses to the new CU 11 during data 
migration by the CPU 10 can be performed. 

Upon receipt of an access by the CPU 10 the data 
migration control part 17 inside the new CU 1 1 judges if 
the access is to a region where data migration has not 
been completed or to a region where data migration has 
been completed. When the access is to a region where 
data migration has been completed, the data exists in 
the new CU 1 1 and the new CU 1 1 performs the service 
as represented by the dashed-iine arrow B On the con- 
trary, when the access is to a region where data migra- 
tion has not been completed, the data does not exist in 
the new CU 11. Therefore, data migration control part 
17 performs the service by accessing the old CU 13 as 
represented by the dashed-line arrow C through con- 
nection 16. The relevant data is retrieved from the old 



CU 13 and stored in the cache 18 of the new CU 11. 
Once the CPU 1 0 has operated on the data, the data is 
stored to both the new VOL 12 and the old VOL 14. With 
these operations, access by the CPU 10 during data 

5 migration is enabled 

The interface between the new CU 11 and the old 
CU 13 through data migration control part 17 is control- 
led using the communication protocol of the CPU 10, 
thereby not requiring any specific function for operating 

io theoUCU13. 

Fig. 2 is a flow chart of the operations performed by 
the data migration control part 17 when data migration 
is conducted. Each of the steps of the flowchart in Rg. 2 
can be implemented by the code of a computer pro- 
's gram. After the instruction of starting data migration a 
pre-processing operation (Step 21) is performed where 
the execution condition of data migration is checked, the 
state of data migration is changed and other such pre- 
processing operations are performed. Then migration 

20 management information used to manage data migra- 
tion is initialized (Step 22). In order to manage the data 
migration process the present invention may use either 
a copy pointer which indicates only the present position 
of data migration or a bit map that illustrates with 

25 respect to all tracks or cylinders whether data migration 
has been completed or not completed as the migration 
management information. 

After the above, the migration management infor- 
mation is checked (Step 23). If data migration of all the 

30 data on the old VOL 14 has been completed then a 
post-processing operation is performed (Step 24). The 
post-processing operation includes operations such as 
changing the state of data migration. Thereafter, data 
migration is ended. If data migration of all of the data on 

35 the old VOL 14 has not been completed then a com- 
mand chain for reading in multiple tracks next to the 
track (if it is a first copy, tracks at top region) where data 
migration has been completed is issued (step 25) to the 
old CU 13 based upon the migration management infor- 

40 mat on. 

At this time, the data migration control part 1 7 per- 
forms the emulation of issuing the command chain to 
the old CU 13 the same as if the command chain had 
been issued from the CPU 10 to the CU (1 1) as a Define 

45 Extent/Locate Record/Read Track) command chain. If 
the old CU 13 has a function equivalent to that of the 
new CU 1 1, high speed transferring can be done with 
the dedcated command chain. The data read in from 
the old CU 13 is stored to the cache 18 (step 26) inside 

so the new CU 1 1 temporarily and the data in the cache 18 
is written to the new VOL 1 2 (step 27). 

The reading process from the old CU 13 is per- 
formed by sequential access. Since the old CU 13 is 
provided with a cache 18 same as the new CU11 and a 

55 prefetch function, the data transferring from the cache 
18 of the old CU 13 to the cache 18 of the new CU 11 
can be conducted at high speed. Thus, the data stored 
in the cache 18 of the old CU 1 3 is in effect stored in the 
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cache 18 of the new CU 1 1 (stage) and then destroyed 
when written to the new VOL 1 2 (destage). This destag- 
ing is for the continuous tracks so that when the function 
of destaging a bundle of multiple continuous tracks is 
used, the efficiency of the destaging is improved and 
high speed data migration is enabled. The path for the 
reading in of the data from the old CU 13 to the cache 
1 8 of the new CU 1 1 and the path for destaging the data 
from the cache 18 to the new VOL 12 are different so 
that parallel execution of processings can be performed. 
Thus, the performance of the processing of data migra- 
tion is improved. After data is written to the new VOL 12 
processing is returned to Step 23 where the migration 
management information is checked. 

Fig. 3 is a flowchart of operations performed when 
CPU access is generated during data migration. Each 
of the steps of the flowchart in Fig. 3 may be imple- 
mented by the code of a computer program. 

First when access from the CPU 10 is generated a 
judgement is performed to determine whether the 
access is to a region where data migration has been 
completed or to a region where data migration has not 
been completed (Step 301). This judgement as to 
whether access is to a region where data migration has 
been completed or a region where data migration has 
not been completed is performed based on the above- 
described migration management information. 

H the access is to a region where data migration 
has not been completed, the access from the CPU 10 is 
then judged to determine whether it is a READ or a 
WRITE access (Step 302). rf the access is judged to be 
a READ access it is necessary to read in the data from 
the old CU 13 since the data does not exist in the new 
CU11. 

For this purpose, the connection 15 between the 
CPU 10 and the new CU 1 1 is disconnected (step 303) 
temporarily and the data migration control part 17 
issues a command chain to the old CU 13 for reading 
the relevant tracks (step 304) through connection 16. 

The data migration control part 17 emulates the 
CPU 10 in that it issues a command chain similar to the 
command chain of Define Extent/Locate Record/Read 
track that is issued by the CPU 10. The tracks which 
have been read from the old CU 13 are stored to the 
cache 18 in the new CU 1 1 (step 305) and the channel 
between the CPU 10 and the new CU 1 1 is reconnected 
(step 306). Then as with general cache READ hit 
processing, the data in the cache 18 is processed by 
transferring it to the CPU 1 0 (Step 307). 

H the access is to a region where data migration 
has not been completed and the access is judged to be 
a WRITE access (Step 302). processing proceeds to 
Step 308. In this case, as with the READ access, the 
connection 15 between the CPU 10 and the new CU 1 1 
is temporarily disconnected (Step 308). the old CU 1 3 is 
instructed to read in the relevant tracks (Step 309) 
through connection 1 6, the tracks which have been read 
in from the old CU 13 are stored to the cache 18 in the 



new CU 1 1 (Step 310) and the connection 15 between 
the CPU 10 and the new CU 11 is reconnected (Step 
311). Then the data is transferred from the CPU 10 to 
the cache 18 in the new CU 1 1 (Step 312). Steps 308 
s through 31 1 can be replaced by an operation of writing 
data directly to the old CU 13 through connection 16 
without performing the operations of reading data from 
the old CU 13 as per steps 308 to 31 1. 

After the above connection 15 between the CPU 10 
10 and the new CU 1 1 is disconnected (Step 313) tempo- 
rarily and the data migration control part 17 issues a 
command chain for writing the data to the old CU 13 
(Step 314) through connection 16. The data migration 
control part 17 emulates the CPU 10 by issuing a com- 
75 mand chain similar to a write command chain issued by 
the CPU 10. The data to be written is transferred from 
the cache 18 of the new CU 11 to the old CU 13 through 
connection 16 (Step 315) and then the connection 15 
between the CPU 1 0 and the new CU 1 1 is reconnected 
20 (step 316). 

In steps 305 and 31 0, by storing data from the CPU 
10 to the cache 18 in the new CU 11 and writing the 
data stored in the cache 18 in the new CU 1 1 to the old 
VOL 14 and the new VOL 12 the present invention 
25 allows for data migration with respect to the data to be 
skipped. This is possfole since the data has been 
moved from the old VOL 14 to the new VOL 12 and 
updated before writing therein. Further, the present 
invention allows for repeated access to data in the 
30 cache 18 of the new CU 11 by the CPU 10. When data 
migration is conducted a judgement must be performed 
to determine whether a region is a region to be skipped 
or not. This judgement can be performed by checking 
the migration management information when the migra- 
ns tion management information is in the form of a bit map 
or a copy point In order to improve efficiency a region in 
which data migration is to be skipped should have a 
considerable amount of range such as, for example, two 
cylinders. 

When an access by the CPU 10 is judged to be an 
access to a region where data migration has been com- 
pleted at step 301 a judgement is performed to deter- 
mine whether the access is a READ access or a WRITE 
access (Step 31 7). 

K the access is judged to be an access to a region 
where data migration has been completed and the 
access is a READ access, as the data exists on the new 
CU 11, the data in the cache 18 of the new CU 1 1 or in 
the new VOL 12 is transferred to the CPU 10 as with 
general READ processing (Step 318) and the process- 
ing is completed. 

H the access is judged to be an access to a region 
where data migration has been completed and the 
access is a WRITE access, as with a general WRITE 
processing the data is transferred from the CPU 10 to 
thecache18ofthenewCU11 (Step319). Similartothe 
case where the WRITE access is to a region where data 
migration has not been corrpleted, the connection 15 
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between CPU 10 and new CU 1 1 is temporarily discon- 
nected (Step 320), and a command chain for writing the 
data to the old CU 13 through connection 16 is issued 
by the data migration control part 17 (Step 321). There- 
after the data in the cache 18 of the new CU 11 is trans- 
ferred to the old CU 13 (Step 322) and the connection 
between the CPU 10 and the new CU 1 1 is reconnected 
(Step 323). 

According to the above, when the WRITE access is 
to the region where data migration has been completed 
or the WRITE access is to the region where data migra- 
tion has not been completed, a WRITE process is per- 
formed of writing data from cache 1 8 of the new CU 1 1 
to the old CU 13 (Steps 313 to 316 and Steps 320 to 
323). Thus, the old VOL 14 is always stored with the lat- 
est data. Therefore, after data migration has been com- 
pleted, dual operation of the new VOL 12 and the old 
VOL 14 can be performed immediately. Further, rela- 
tively immediate restart of operation on the side of the 
old CU 13 can be performed after the failure of the new 
VOL 12 during data migration. Still further, due to the 
operations described above a WRITE access can be 
safely conducted during data migration. 

Re. 4 is a flowchart which illustrates the operations 
performed for the automatic adjustment of migration 
speed during data migration. Each of the steps of the 
flowchart in Fig. 4 may be implemented by the code of a 
computer program. 

In Fig. 4 when conducting data migration, a 
processing to store information indicating the specified 
order of priority of data migration of the plural VOLs 
(Step 41 ) is required, when processing an instruction for 
the old CU 13 to read in tracks of data, the queuing time 
of the command chains caused by contentions for the 
connection 16 between the new CU 11 and the old CU 
13, the existence of the contentions for the same VOL 
by accesses from the CPU and the utilization of migra- 
tion speed according to the current settings are meas- 
ured (Step 42). 

The processing of migration speed adjustment is, 
as shown in Fig. 4, performed at a set timing according 
to a timer. Thus, information of data migration sequence 
of priority stored during the data migration process is 
acquired (Step 43). 

Then cache resource information indicating the uti- 
lization of the cache 16 of the new CU 1 1 is acquired 
and compiled (Step 44). The utilization factor of the 
cache is determined based on all processings in the 
new CU 1 1 utilizing the cache 1 8 including the process- 
ings related to data migration. The utilization factor is 
calculated by counting the number of segments of the 
cache 1 8 that are not used. 

Then path resource information indicating utiliza- 
tion of the path between the new and the old CUs 1 1 
and 13 is aoquired and complied (Step 45). The average 
queuing time of the command chains for data migration 
caused by the generation of contentions for the path 
between new and old CU s 1 1 and 13, measured during 



data migration, is used as the path resource informa- 
tion. For the queuing time, the rate of the change of the 
average value is calculated using past information. 
Then old VOL resource information indicating utiG- 

5 zation of the old VOL 1 4 is acquired and complied (Step 
46). The sum of the existence of contentions of com- 
mand chains for data migration by accesses from the 
CPU 10 to the same VOL 12, 14, measured during data 
migration, is used as the old VOL resource information. 

io For the sum of the existence of contentions, the rate of 
the change of the existence of contentions is calculated 
using past information. 

Based on the order of the priority of sequence of 
data migration and the various resource information, a 

is judgement is performed to determine whether migration 
speed should be changed (Step 47). The migration 
speed is changed by manipulating at least one of the fol- 
lowing two items. If the change is judged to be unneces- 
sary, the processing is finished. If the change is judged 

20 to be necessary, the processing proceeds to the Step 
48. In the Step 48. there are two items to be adjusted. 
One of the two items is the number of tracks to be read 
in at one command chain for data migration. The other 
of the two items is the issuing interval of the command 

25 chains for data migration. When the various resource 
information indicates the tendency of an increase of 
access by the CPU, the number of the tracks to be read 
in is reduced or the issuing interval of the <»mmand 
chains issued by the CPU that have been given priority 

30 is lengthened. 

The present invention allows for the setting of a 
VOL with higher priority such that migration speed is not 
reduced even when access by the CPU 10 is increas- 
ing. 

35 By use of the present invention, writing of data to 
the old and new VOLs can be safely conducted during 
data migration. Also access by the CPU can be con- 
ducted with certainty to the VOLs even though data 
migration has not been completed. 

40 Further, by use of the present invention, the same 
data is stored on the new and the old volumes in the 
region where data migration has been completed. Thus, 
immediate switching to dual operation using both old 
and new volumes is enabled after data migration has 

45 been completed. In addition, faster switching to the old 
volume when failure has occurred in the new volume 
during the migration is enabled. 

Still further, by use of the present invention the 
migration speed can be automatically adjusted based 

so on the priority order given the volumes. Thus, faster 
migration of the volume with higher priority is enabled 
while giving priority to accesses from the CPU during 
data migration. 

Still further yet by use of the present invention, the 

55 data migration process can be skipped on tracks previ- 
ously accessed by the CPU where data migration had 
not been completed since data migration is performed 
at the time of the previous access. Thus, when the 
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tracks are accessed repeatedly, these accesses are 
processed with the cache of the new CU. thereby 
improving access performance of the CPU during data 
migration. 

While the present invention has been described in 5 
detail and pictorially in the accompanying drawings it is 
not limited to such details since many changes and 
modifications recognizable to those of ordinary skill in 
the art may be made to the invention without departing 
from the spirit and the scope thereof. 10 

Claims 

1. A method of controlling data migration in an infor- 
mation processing system which includes a CPU. a 15 
new storage system connected to said CPU and an 

old storage system connected to said new storage 
system, wherein data migration is conducted to 
transfer data from said old storage system to said 
new storage system, said method comprising the 20 
steps of: 

permitting access to said storage systems by 
said CPU during data migration; 
determining whether said access is to a region 25 
where data migration has been completed; 
processing said access to said new storage 
system when said access is to a region where 
data migration has been completed; and 
processing said access to said old storage sys- 30 
tern and transferring data related to said 
access from said old storage system to said 
new storage system when said access is to a 
region where data migration has not been com- 
pleted. 35 

2. The method of claim 1 , wherein each storage sys- 
tem is implemented by a disk subsystem which 
includes a disk controller and a disk volume. 

40 

3. The method of claim 2, wherein said disk controller 
of said new storage system includes a cache mem- 
ory for temporarily storing said data related to said 
access transferred from said old storage system, 
wherein said cache memory is accessible by said 45 
CPU. 

4. The method of claim 1, wherein said step of 
processing said access to said new storage system 
comprises the steps of: so 

checking whether said access is a READ 
access or a WRITE access; 
when said access is a READ access, transfer- 
ring data related to said access from said new 55 
storage system to said CPU; and 
when said access is a WRITE access, transfer- 
ring data related to said access from said CPU 



to both said new storage system and said old 
storage system. 

5. The method of claim 1, wherein said step of 
processing said access to said old storage system 
comprises the steps of: 

checking whether said access is a READ 
access or a WRITE access; 
when said access is a READ access, transfer- 
ring data related to said access from said old 
storage system to said new storage system 
and transferring said data from said new stor- 
age system to said CPU; and 
when said access is a WRITE access, transfer- 
ring data related to said access from said old 
storage system to said new storage system, 
transferring data from said CPU to said new 
storage system so as to be combined with said 
data transferred from said old storage system 
and transferring said combined data to said old 
storage system. 

6. The method of claim 1 further comprising the step 
of adjusting speed of data migration based on 
resource information acquired from said informa- 
tion processing system. 

7. The method of claim 6, wherein said resource infor- 
mation acquired from said information processing 
system includes cache resource information indi- 
cating utilisation of a cache memory included in 
said new storage system, path resource informa- 
tion indicating utilisation of the connection between 
said new storage system and said old storage sys- 
tem and old storage system resource information 
indicating utilisation of said old storage system. 

8. The method of claim 7, wherein said resource infor- 
mation further includes information concerning utili- 
sation of data migration speed according to current 
settings. 

9. The method of claim 6 or 7, wherein data migration 
speed is adjusted in a manner so as to give priority 
to accesses to said new storage system. 

10. A server for controlling data migration with respect 
to another server in an information processing sys- 
tem which includes a CPU, wherein data migration 
is conducted to transfer data from said other server 
to said server, said server comprising: 

a storage for storing data; and 
a data migration control part for permitting 
access by said CPU to said servers during data 
migration, determining whether said access is 
to a region where data migration has been 
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completed, processing said access to said 
server when said access is to a region where 
data migration has been completed, and 
processing said access to said other server 
and transferring data related to said access 5 
from said other server to said server when said 
access is to a region where data migration has 
not been completed. 

11. The server of claim 10, wherein each server is 10 
implemented by a disk subsystem which includes a 
disk controller and a disk volume as said storage. 

12. The server of claim 1 1 , wherein said disk controller 

of said server includes a cache memory for tempo- 15 
rarily storing said data related to said access trans- 
ferred from said other server, wherein said cache 
memory is accessible by said CPU. 



1 7. The server of claim 1 6, wherein said resource infor- 
mation further includes information concerning utili- 
sation of data migration speed according to current 
settings. 

18. The server of claim 15 or 16, wherein said data 
migration control part adjusts data migration speed 
in a manner so as to give priority to accesses to 
said server. 

19. An information processing system which includes a 
CPU and a plurality of servers as defined in any of 
claims 10 to 18, wherein one of said servers con- 
trols data migration with respect to another server 
and data migration is conducted to transfer data 
from said other server to said one server. 



1 3. The server of claim 1 0, wherein said data migration 20 
control part, when processing said access to said 
server, checks whether said access is a READ 
access or a WRITE access, transfers data related 
to said access from said server to said CPU when 
said access is a READ access, transfers data 2$ 
related to said access from said CPU to both said 
server and said other server when said access is a 
WRITE access. 



14. The server of claim 10, wherein said data migration 30 
control part, when processing said access to said 
other server, checks whether said access is a 
READ access or a WRITE access, transfers data 
related to said access from said other server to said 
server and transfers said data from said server to 35 
said CPU when said access is a READ access, and 
transfers data related to said access from said 
other server to said server, transfers data from said 
CPU to said server so as to be combined with said 
data transferred from said other server and trans- 40 
fers said combined data to said other server when 
said access is a WRITE access. 



1 5. The server of daim 1 0, wherein said data migration 
control part adjusts the speed of data migration 45 
based on resource information acquired from said 
information processing system. 

1 6. The server of claim 1 5, wherein said resource infor- 
mation acquired from said information processing so 
system includes cache resource information indi- 
cating utilisation of a cache memory included in 
said server, path resource information indicating 
utilisation of the connection between said server 
and said other server and another server system 55 
resource information indicating utilisation of said 
other server. 
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